PangoAttrColor *fg_color,
gboolean *fg_set,
PangoAttrColor *bg_color,
- gboolean *bg_set);
+ gboolean *bg_set,
+ gboolean *shape_set);
static void
gdk_pango_context_destroy (GdkPangoContextInfo *info)
PangoUnderline uline = PANGO_UNDERLINE_NONE;
PangoLayoutRun *run = tmp_list->data;
PangoAttrColor fg_color, bg_color;
- gboolean fg_set, bg_set;
+ gboolean fg_set, bg_set, shape_set;
GdkGC *fg_gc;
tmp_list = tmp_list->next;
- gdk_pango_get_item_properties (run->item, &uline, &fg_color, &fg_set, &bg_color, &bg_set);
-
- if (fg_set)
- fg_gc = gdk_pango_get_gc (context, &fg_color, gc);
- else
- fg_gc = gc;
+ gdk_pango_get_item_properties (run->item, &uline, &fg_color, &fg_set, &bg_color, &bg_set, &shape_set);
if (uline == PANGO_UNDERLINE_NONE)
pango_glyph_string_extents (run->glyphs, run->item->analysis.font,
gdk_pango_free_gc (context, bg_gc);
}
+ if (shape_set)
+ continue;
+
+ if (fg_set)
+ fg_gc = gdk_pango_get_gc (context, &fg_color, gc);
+ else
+ fg_gc = gc;
+
gdk_draw_glyphs (drawable, fg_gc, run->item->analysis.font,
- x + x_off / PANGO_SCALE, y, run->glyphs);
+ x + x_off / PANGO_SCALE, y, run->glyphs);
switch (uline)
{
PangoAttrColor *fg_color,
gboolean *fg_set,
PangoAttrColor *bg_color,
- gboolean *bg_set)
+ gboolean *bg_set,
+ gboolean *shape_set)
{
GSList *tmp_list = item->extra_attrs;
if (bg_set)
*bg_set = FALSE;
+
+ if (shape_set)
+ *shape_set = FALSE;
while (tmp_list)
{
*bg_set = TRUE;
break;
+
+ case PANGO_ATTR_SHAPE:
+ if (shape_set)
+ *shape_set = TRUE;
+ break;
default:
break;